System and method for managing files in flash memory

ABSTRACT

A system and method for managing files in a flash memory. The flash memory has a first storage area and a second storage area for storing files. Each of the files has a file header and a data block. The method includes writing the file header of each of the files into the first storage area and setting the first storage area as a first mode, writing the data block of each of the files into the second storage area and setting the second area as a second mode. Responding to the data block of one of the files being completely written into the second storage area, a memory address of the data block stored in the second storage area is written to a corresponding file header.

BACKGROUND

1. Technical Field

Embodiments of the present disclosure generally relate to techniques of file management, and more particularly to a system and method for managing files in flash memory.

2. Description of Related Art

A flash memory device is a particular type of non-volatile electrically erasable programmable read-only memory (EEPROM) device that can be electrically erased and reprogrammed. Because of this property, flash memory is widely used in a mobile communication device, and a storing speed can be enhanced. In general, a large number of files are stored in the flash memory, and occupy bulky space, which would seriously effect application efficiency of the flash memory.

What is needed, therefore, is a system and method for managing files in the flash memory, so as to overcome the above-described shortcomings and effectively use storage space of the flash memory.

BRIEF DESCRIPTION OF THE DRAWINGS

FIG. 1 is a block diagram of one embodiment of a system for managing files in flash memory.

FIG. 2 is a block diagram of one embodiment of function modules of a file managing unit included in the system of FIG. 1.

FIG. 3 is a flowchart illustrating one embodiment of a method for managing files in flash memory.

FIG. 4 including FIG. 4 a and FIG. 4 b show a schematic diagram illustrating one embodiment of two storage areas of the flash memory.

DETAILED DESCRIPTION

The invention is illustrated by way of example and not by way of limitation in the figures of the accompanying drawings in which like references indicate similar elements. It should be noted that references to “an” or “one” embodiment in this disclosure are not necessarily to the same embodiment, and such references mean at least one.

In general, the word “module,” as used herein, refers to logic embodied in hardware or firmware, or to a collection of software instructions, written in a programming language, such as, for example, Java, C, or assembly. One or more software instructions in the modules may be embedded in firmware, such as an EPROM. It will be appreciated that modules may comprised connected logic units, such as gates and flip-flops, and may comprise programmable units, such as programmable gate arrays or processors. The modules described herein may be implemented as either software and/or hardware modules and may be stored in any type of computer-readable medium or other computer storage device.

FIG. 1 is a block diagram of one embodiment of a system for managing files in flash memory 12. In one embodiment, the flash memory 12 is installed in a mobile communication device 1, for example, a mobile phone or a personal digital assistant. The mobile communication device 1 typically includes a file managing unit 10, at least one processor 14, and a storage system 16. The file managing unit 10 is operable to partition a storage space of the flash memory 12 into two storage areas, such as a first storage area 120 and a second storage area 122 (as shown in FIG. 4). In the embodiment, each of the files includes a file header and a data block. The file managing unit 10 stores the file header and the data block of each of the files in the first storage area 120 and the second storage area 122 respectively, in order to manage the files effectively. In the embodiment, the file header includes, but not limited to, a file name and a memory address of a corresponding data block stored in the second storage area 122. The file managing unit 10 may be stored in the storage system 16. The storage system 16 may be a hard disk drive, a compact disc, a digital video disc, or a tape drive.

FIG. 2 is a block diagram of one embodiment of function modules of the file managing unit 10 of FIG. 1. The file managing unit 10 may include a plurality of instructions, and executed by the processor 14 of the mobile communication device 1. In one embodiment, the file managing unit 10 may include a managing module 100, a determining module 102, an inquiring module 104, and an updating module 106.

The managing module 100 is operable to write the file header of each of the files into the first storage area 120 of the flash memory 12, and set the first storage area 120 as a first mode. The managing module 100 is further operable to write the data block of each of the files into a second storage area 122 of the flash memory 12, and set the second storage area 122 as a second mode. In the embodiment, the first mode may be a control mode designating that files in the control mode can be edited, and the second mode may be an object mode designating that files in the object mode cannot be edited. The file header of each of the files in the first storage area 120 can be set as a predetermined size (e.g., 128 kilobits), and the file header of all of the files are arranged in the first storage area 120 in a queue. As shown in FIG. 4 a, a file header 1, a file header 2, a file header 3, and a file header N are arranged in the first storage area 120. The data block of each of the files in the second storage area 122 represents contents of a corresponding file. The data block of all the files are arranged in the second storage area 122 orderly. As shown in FIG. 4 b, a data block 1, a data block 2, a data block 3, and a data block N are arranged in the second storage area 122.

Responding to the managing module 100 have finished writing the data block into the second storage area 122 completely, the managing module 100 is further operable to write a memory address of the new data block of the second storage area 122 into a corresponding file header. For example, if one file includes a file header “a” and a data block “b”, the managing module 100 writes the file header “a” to the first storage area 120 of the flash memory 12, and then writes the data block “b” to the second storage area 122. After the data block “b” is completely written in the second storage area 122, the managing module 100 may write a memory address of the data block stored in the second storage area 122 to the file header 1. For example, if the memory address of the data block “b” stored in the second storage area 122 is “x,” the managing module 100 may write the memory address “x” to the file header 1.

The determining module 102 is operable to determine whether a control command is received from a user. The control command indicates that a requested file will be read from the flash memory 12 or written into storage areas of the flash memory 12. In the embodiment, the control command at least includes a file name of the requested file.

If the determined module 102 detects the control command, the inquiring module 104 is operable to search the requested file from the first storage area 120 according to the file name of the requested file, and the determining module 102 is further operable to detect whether the first storage area 120 stores a file header of the requested file. If the file header of the requested file is found in the first storage area 120, the inquiring module 104 reads the requested file from the second storage area 122 according to the memory address of the requested file referenced by the file header.

In another embodiment, if the inquiring module 104 detects that contents of the requested file is not new, the updating module 106 is operable to update the requested file in the flash memory 12.

FIG. 3 is a flowchart illustrating one embodiment of a method for managing files in flash memory 12 by using the file managing unit 10 as described in FIG. 1. Depending on the embodiment, additional blocks in the flow of FIG. 3 may be added, others removed, and the ordering of the blocks may be changed.

In block S300, the managing module 100 writes a file header of each of the files into a first storage area 120 of the flash memory 12, and sets the first storage are 120 as a first mode. In the embodiment, the first mode may be a control mode designating that files in the control mode can be edited. The file header of each of the files in the first storage area 120 can be set as a predetermined size (e.g., 128 kilobits), and the file header of all of the files are arranged in the first storage area 120 orderly, as shown in FIG. 4 a.

In block S302, the managing module 100 writes a data block of each of the files into a second storage area 122 of the flash memory 12, and sets the second storage area 122 as a second mode. In the embodiment, the second mode may be an object mode, the data clock of all of the files are stored in the second storage area 122 orderly, as shown in FIG. 4 b, and each data block in the second storage area 122 has a memory address.

Responding to the managing 100 have finished writing the data block into the second storage area 122 completely, in block S304, the managing module 100 writes a memory address of each data block into a corresponding file header.

In block S306, the determining module 102 detects whether a control command is received from a user. The control command at least includes a file name of a requested file. In the embodiment, if no control command is received, the flow directly ended. Otherwise, if one control command is received, the flow enters block S308 as blow.

In block S308, the inquiring module 104 searches the requested file from the first storage area 120 according to the control command.

In block S310, the determining module 102 detects whether the first storage area 120 stores a file header of the requested file. If the first storage area 120 does not store the file header of the requested file, the flow directly ends.

In response to the first storage area 120 stores the file header of the requested file, in block S312, the inquiring module 104 reads the requested file from the second storage area 122 according to the memory address referenced by the file header.

In another embodiment, if the requested file is not a new file, the updating module 106 can update the requested file in the second storage area 122 of the flash memory 12.

Although certain inventive embodiments of the present disclosure have been specifically described, the present disclosure is not to be construed as being limited thereto. Various changes or modifications may be made to the present disclosure without departing from the scope and spirit of the present disclosure. 

1. A computer-implemented method for managing files in a flash memory, the method comprising: partitioning the flash memory into a first storage area and a second storage area; writing a file header of each of the files to the first storage area; setting the first storage area as a first mode; writing a data block of each of the files to the second storage area; setting the second storage area as a second mode; and responding to the data block of one of the files being completely written into the second storage area, writing a memory address of the data block stored in the second storage area to a file header corresponding to the file.
 2. The method as described in claim 1, wherein the first mode is a control mode, and the second mode is an object mode.
 3. The method as described in claim 1, wherein the file header at least stores a file name and the memory address of the data block stored in the second storage area.
 4. The method as described in claim 2, further comprising: searching a requested file in the first storage area according to the file name of the requested file after a control command is received from a user; and reading the requested file from the second storage area according to the memory address of the requested file stored in the file header.
 5. The method as described in claim 4, wherein the control command at least comprises a file name of the requested file.
 6. A storage medium having stored thereon instructions that, when executed by a processor, causing the processor to manage files in a flash memory, wherein the method comprises: partitioning the flash memory into a first storage area and a second storage area; writing a file header of each of the files to the first storage area; setting the first storage area as a first mode; writing a data block of each of the files to the second storage area; setting the second storage area as a second mode; and responding to the data block of one of the files being completely written into the second storage area, writing a memory address of the data block stored in the second storage area to a file header corresponding to the file.
 7. The storage medium as described in claim 6, wherein the first mode is a control mode, and the second mode is an object mode.
 8. The storage medium as described in claim 6, wherein the file header at least stores a file name and the memory address of the data block stored in the second storage area.
 9. The storage medium as described in claim 8, wherein the method further comprises: searching a requested file in the first storage area according to the file name of the requested file after a control command is received from a user; and reading the requested file from the second storage area according to the memory address of the requested file stored in the file header.
 10. The storage medium as described in claim 9, wherein the control command at least comprises a file name of the requested file.
 11. A system for managing files in a flash memory, wherein the flash memory is partitioned into a first storage area and a second storage area for storing files, the system comprising: a managing module operable to write a file header of each of the files to the first storage area and set the first storage area as a first mode, write the data block of each of the files to the second storage area and set the second storage area as a second mode, and write a memory address of the data block stored in the second storage area to a file header corresponding to the file after the managing module writes the data block to the second storage area completely.
 12. The system as described in claim 11, wherein the first mode is a control mode, and the second mode is an object mode.
 13. The system as described in claim 11, wherein the file header at least stores a file name and the memory address of the data block stored in the second storage area.
 14. The system as described in claim 13, further comprising an inquiring module operable to search a requested file from the first storage area according to the file name of the requested file after a control command is received from a user, and read the requested file from the second storage area according to the memory address referenced by the file header.
 15. The system as described in claim 14, wherein the control command at least comprises the file name of the requested file. 